package com.xrit.sunnyday.dao;

import com.xrit.sunnyday.pojo.Permission;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

public interface PermissionDao {

    /*
     * 查询所有的权限
     * */
    List<Permission> findAll();

    /*
     * 分页
     * */
    List<Permission> findPage(String queryPageBean);

    /*
     * 添加
     * */
    void add(Permission permission);

    /*
     * 通过id查询
     * */
    Permission findById(int id);

    /*
     * 修改
     * */
    void edit(Permission permission);

    /*
     * 删除
     * */
    void delete(int id);

    //    建立角色与权限的关系
    @Insert("insert into t_role_permission (role_id, permission_id) values (#{RoleId},#{permissionId})")
    void RolePermissionAdd(@Param("RoleId") Integer RoleId, @Param("permissionId") Integer permissionId);

    //    根据角色ID查询角色与权限是否有关系
    @Select("SELECT COUNT(1) FROM `t_role_permission` WHERE role_id = #{id}")
    Integer QueryRolePermissionByRoleId(Integer id);

    //    根据RoleID删除t_role_permission角色与权限关系
    @Delete("DELETE FROM t_role_permission WHERE role_id = #{id}")
    void RolePermissionDeleteByRoleId(Integer id);

}
